

|   | L # | Hits | Search Text                                                                         | DBs                                 |
|---|-----|------|-------------------------------------------------------------------------------------|-------------------------------------|
| 1 | L2  | 869  | (access\$3 writ\$3 updat\$3) near10 ((branch near5 (table history predict\$3)) bht) | USPAT;<br>US_PGPUB                  |
| 2 | L4  | 207  | (access\$3 writ\$3 updat\$3) near10 ((branch near5 (table history predict\$3)) bht) | EPO;<br>JPO;<br>DERWENT;<br>IBM_TDB |
| 3 | L7  | 220  | 2 near10 (control controlled controlling simultaneous\$3 clock cycle)               | USPAT;<br>US_PGPUB                  |
| 4 | L6  | 29   | 4 near10 (control controlled controlling simultaneous\$3 clock cycle)               | EPO;<br>JPO;<br>DERWENT;<br>IBM_TDB |

|   |   |   |   |   |   |
|---|---|---|---|---|---|
|   |   |   |   |   |   |
| F | 7 | - | 1 | 0 | 0 |
| E | 6 | - | 1 | 0 | 0 |
| D | 3 | 5 | 1 | 1 | 0 |
| C | 0 | 2 | 1 | 1 | 0 |
| B | 0 | - | 1 | 0 | 1 |
| A | 0 | - | 1 | 0 | 1 |

Pointer → 448  
446  
444  
442  
440

450  
Return Stack Storage 252

FIG. 4D

|   |    |    |   |   |   |
|---|----|----|---|---|---|
|   |    |    |   |   |   |
| G | 11 | -  | 1 | 0 | 0 |
| F | 7  | 8  | 1 | 1 | 0 |
| E | 6  | 9  | 1 | 1 | 0 |
| D | 3  | 5  | 1 | 1 | 0 |
| C | 0  | 2  | 1 | 1 | 0 |
| B | 0  | 10 | 1 | 1 | 1 |
| A | 0  | -  | 1 | 0 | 1 |

Pointer → 448  
446  
444  
442  
440

452  
450  
Return Stack Storage 252

FIG. 4E

|    | Docum<br>ent<br>ID          | U                                   | Title                                                                                                                                                                                                                       | Current<br>OR |
|----|-----------------------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 1  | JP<br>20011<br>00995<br>A   | <input type="checkbox"/>            | DEVICE AND METHOD FOR WRITE CONTROL OVER BRANCH HISTORY INFORMATION                                                                                                                                                         |               |
| 2  | JP<br>11110<br>224 A        | <input checked="" type="checkbox"/> | LANGUAGE PROCESSING DEVICE, ITS METHOD AND INFORMATION STORAGE MEDIUM                                                                                                                                                       |               |
| 3  | JP<br>10171<br>652 A        | <input checked="" type="checkbox"/> | METHOD AND DEVICE FOR UPDATING OF BRANCH HISTORY TABLE                                                                                                                                                                      |               |
| 4  | JP<br>09083<br>552 A        | <input checked="" type="checkbox"/> | MULTIPROTOCOL CONTROL METHOD                                                                                                                                                                                                |               |
| 5  | JP<br>06236<br>270 A        | <input checked="" type="checkbox"/> | METHOD AND DEVICE FOR IMPROVING BRANCH HISTORY PREDICTING PRECISION IN SUPERSCALAR PROCESSOR SYSTEM                                                                                                                         |               |
| 6  | JP<br>04242<br>431 A        | <input checked="" type="checkbox"/> | INFORMATION PROCESSOR                                                                                                                                                                                                       |               |
| 7  | JP<br>02031<br>237 A        | <input checked="" type="checkbox"/> | GENERATING SYSTEM FOR OPTIMUM BRANCH INSTRUCTION                                                                                                                                                                            |               |
| 8  | JP<br>01216<br>427 A        | <input checked="" type="checkbox"/> | DATA PROCESSOR                                                                                                                                                                                                              |               |
| 9  | JP<br>63189<br>943 A        | <input checked="" type="checkbox"/> | BRANCH FORECASTING CONTROL SYSTEM                                                                                                                                                                                           |               |
| 10 | JP<br>63005<br>442 A        | <input checked="" type="checkbox"/> | PROGRAM LOOP DETECTING AND STORING DEVICE                                                                                                                                                                                   |               |
| 11 | JP<br>62262<br>143 A        | <input checked="" type="checkbox"/> | GRAPHICAL LANGUAGE TRANSLATING DEVICE                                                                                                                                                                                       |               |
| 12 | JP<br>62130<br>460 A        | <input checked="" type="checkbox"/> | DOCUMENT GENERATION SYSTEM INSTRUCTED BY BRANCH OFFICE                                                                                                                                                                      |               |
| 13 | JP<br>60175<br>148 A        | <input checked="" type="checkbox"/> | INSTRUCTION PREFETCHING DEVICE                                                                                                                                                                                              |               |
| 14 | JP<br>60164<br>842 A        | <input checked="" type="checkbox"/> | INSTRUCTION PREFETCHING DEVICE                                                                                                                                                                                              |               |
| 15 | JP<br>57147<br>197 A        | <input checked="" type="checkbox"/> | MEMORY PROTECTION SYSTEM                                                                                                                                                                                                    |               |
| 16 | EP<br>60587<br>6 A1         | <input checked="" type="checkbox"/> | Method and system for enhanced branch history prediction accuracy in a superscalar processor system.                                                                                                                        |               |
| 17 | NA900<br>1369               | <input checked="" type="checkbox"/> | Branch Resolution in the Cache                                                                                                                                                                                              |               |
| 18 | NN831<br>02283              | <input checked="" type="checkbox"/> | Functional AC Card Test Using a DC Tester                                                                                                                                                                                   |               |
| 19 | US<br>63473<br>69 B         | <input checked="" type="checkbox"/> | Microprocessor operating method involves reading counter values from branch history table in response to accessing branch history table using generated primary and secondary branch history table indexes                  |               |
| 20 | US<br>20010<br>02026<br>7 A | <input checked="" type="checkbox"/> | Pipeline processing apparatus controls supply of updated latest branch prediction status to succeeding conditional branch instruction by comparing the branch instruction at preceding pipeline stage with succeeding stage |               |
| 21 | US<br>59789<br>07 A         | <input checked="" type="checkbox"/> | Updating method of storage arrays in superscalar microprocessor                                                                                                                                                             |               |
| 22 | US<br>58782<br>55 A         | <input checked="" type="checkbox"/> | Delayed update unit for branch prediction array for superscalar microprocessor                                                                                                                                              |               |



|    | Document ID          | U                                   | Title                                                                                                                                                                                                                                                     | Current OR |
|----|----------------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 23 | US<br>58753<br>24 A  | <input checked="" type="checkbox"/> | Delayed updating mechanism for branch prediction array in superscalar microprocessor                                                                                                                                                                      |            |
| 24 | JP<br>09244<br>892 A | <input checked="" type="checkbox"/> | CPU for computer - includes effective request flag in read-out buffer which indicates effect of error in branch prediction on read-out data field                                                                                                         |            |
| 25 | AU<br>95232<br>31 A  | <input checked="" type="checkbox"/> | Memory control system for private branch exchange - has memory table in CPU with read circuit accessing information file in secondary memory for storage in table for access unit control                                                                 |            |
| 26 | EP<br>66761<br>8 A   | <input checked="" type="checkbox"/> | Access control method for particular address on disc - providing branch data for one control method in table used by different control method                                                                                                             |            |
| 27 | EP<br>65133<br>1 A   | <input type="checkbox"/>            | Write buffer for super-pipelined super-scalar microprocessor - directs each write to memory to write buffer rather than memory bus or cache memory and writes contents of write buffer to cache or main memory when memory bus or cache becomes available |            |
| 28 | EP<br>60587<br>6 A   | <input type="checkbox"/>            | Branch history prediction for processor - using branch history table with predictive field for each fetch cycle in multiple instruction access accessed by partial instruction address for updating                                                       |            |
| 29 | EP<br>25845<br>3 B   | <input type="checkbox"/>            | Instruction prefetch control appts. for data processor - has branch history table storing paired branch instruction address and branch destination address of branch instruction                                                                          |            |

Although the present invention has been described with regard to a specific embodiment, other modifications and improvements will occur to those skilled in the art. For instance, many of the functions illustrated above to a particular portion of a data processor may be performed by a different portion of a particular data processor. The name of the unit performing a necessary function or the division of the system among a group of units, therefore, is not part of the invention. It is to be understood, therefore, that the invention encompasses all such modifications that do not depart from the spirit and scope of the invention as defined in the appended claims.

Both paths within flow chart 36 then merge at the end of file 16.

Fig. 8 depicts a flow chart of one set of steps needed to implement a second order autocalibration scheme. Upon execution of the second order autocalibration routine, the user specifies the branch, the controls of the MRA bits would be stored in the second Shadow MRA bits. Recombine buffer 14 will then restore the Nth Shadow MRA bits to the MRA bits if the data processor's branch unit determines that the Nth outcome sampling specification branch is incorrect (where N is an integer index). In general, one Shadow MRA bit may be provided for each level of speculative branching that is desired.

|    | Document ID                  | U                                   | Title                                                                                            | Current OR  |
|----|------------------------------|-------------------------------------|--------------------------------------------------------------------------------------------------|-------------|
| 1  | US<br>20020<br>17432<br>8 A1 | <input type="checkbox"/>            | Method for cancelling speculative conditional delay slot instructions                            | 712/235     |
| 2  | US<br>20020<br>17432<br>2 A1 | <input checked="" type="checkbox"/> | Method for cancelling conditional delay slot instructions                                        | 712/218     |
| 3  | US<br>20020<br>08779<br>4 A1 | <input checked="" type="checkbox"/> | Apparatus and method for speculative prefetching after data cache misses                         | 711/126     |
| 4  | US<br>20020<br>08331<br>0 A1 | <input checked="" type="checkbox"/> | METHOD AND APPARATUS FOR PREDICTING LOOP EXIT BRANCHES                                           | 712/233     |
| 5  | US<br>20020<br>08067<br>7 A1 | <input checked="" type="checkbox"/> | Semiconductor memory device                                                                      | 365/233     |
| 6  | US<br>20020<br>07833<br>2 A1 | <input checked="" type="checkbox"/> | Conflict free parallel read access to a bank interleaved branch predictor in a processor         | 712/240     |
| 7  | US<br>20020<br>06937<br>5 A1 | <input checked="" type="checkbox"/> | System, method, and article of manufacture for data transfer across clock domains                | 713/400     |
| 8  | US<br>20010<br>02751<br>5 A1 | <input checked="" type="checkbox"/> | Apparatus and method of controlling instruction fetch                                            | 712/207     |
| 9  | US<br>20010<br>02197<br>4 A1 | <input checked="" type="checkbox"/> | Branch predictor suitable for multi-processing microprocessor                                    | 712/240     |
| 10 | US<br>20010<br>02026<br>7 A1 | <input checked="" type="checkbox"/> | Pipeline processing apparatus with improved efficiency of branch prediction, and method therefor | 712/239     |
| 11 | US<br>20010<br>02026<br>5 A1 | <input checked="" type="checkbox"/> | Data processor with multi-command instruction words                                              | 712/24      |
| 12 | US<br>20010<br>01690<br>3 A1 | <input checked="" type="checkbox"/> | Software branch prediction filtering for a microprocessor                                        | 712/239     |
| 13 | US<br>20010<br>01134<br>6 A1 | <input checked="" type="checkbox"/> | Branch prediction method, arithmetic and logic unit, and information processing apparatus        | 712/239     |
| 14 | US<br>20010<br>00753<br>3 A1 | <input checked="" type="checkbox"/> | Non-volatile semiconductor memory device and semiconductor disk device                           | 365/185 .11 |
| 15 | US<br>64670<br>64 B1         | <input checked="" type="checkbox"/> | Viterbi decoder                                                                                  | 714/795     |
| 16 | US<br>64532<br>78 B1         | <input checked="" type="checkbox"/> | Flexible implementation of a system management mode (SMM) in a processor                         | 703/27      |
| 17 | US<br>64456<br>15 B2         | <input checked="" type="checkbox"/> | Non-volatile semiconductor memory device and semiconductor disk device                           | 365/185 .11 |
| 18 | US<br>64426<br>79 B1         | <input checked="" type="checkbox"/> | Apparatus and method for guard outcome prediction                                                | 712/218     |



|    | Document ID    | U                                   | Title                                                                                                                                                | Current OR |
|----|----------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 19 | US 64386 82 B1 | <input checked="" type="checkbox"/> | Method and apparatus for predicting loop exit branches                                                                                               | 712/241    |
| 20 | US 64386 64 B1 | <input checked="" type="checkbox"/> | Microcode patch device and method for patching microcode using match registers and patch routines                                                    | 711/154    |
| 21 | US 64271 92 B1 | <input checked="" type="checkbox"/> | Method and apparatus for caching victimized branch predictions                                                                                       | 711/133    |
| 22 | US 64250 75 B1 | <input checked="" type="checkbox"/> | Branch prediction device with two levels of branch prediction cache                                                                                  | 712/239    |
| 23 | US 63973 26 B1 | <input checked="" type="checkbox"/> | Method and circuit for preloading prediction circuits in microprocessors                                                                             | 712/240    |
| 24 | US 63935 49 B1 | <input checked="" type="checkbox"/> | Instruction alignment unit for routing variable byte-length instructions                                                                             | 712/204    |
| 25 | US 63743 51 B1 | <input checked="" type="checkbox"/> | Software branch prediction filtering for a microprocessor                                                                                            | 712/239    |
| 26 | US 63599 09 B1 | <input checked="" type="checkbox"/> | Switch device for relayin G cells or packets on demand                                                                                               | 370/522    |
| 27 | US 63538 82 B1 | <input checked="" type="checkbox"/> | Reducing branch prediction interference of opposite well behaved branches sharing history entry by static prediction correctness based updating      | 712/239    |
| 28 | US 63517 97 B1 | <input checked="" type="checkbox"/> | Translation look-aside buffer for storing region configuration bits and method of operation                                                          | 711/207    |
| 29 | US 63517 89 B1 | <input checked="" type="checkbox"/> | Built-in self-test circuit and method for validating an associative data array                                                                       | 711/128    |
| 30 | US 63473 69 B1 | <input checked="" type="checkbox"/> | Method and circuit for single cycle multiple branch history table access                                                                             | 712/240    |
| 31 | US 63413 48 B1 | <input checked="" type="checkbox"/> | Software branch prediction filtering for a microprocessor                                                                                            | 712/239    |
| 32 | US 63361 78 B1 | <input checked="" type="checkbox"/> | RISC86 instruction set                                                                                                                               | 712/23     |
| 33 | US 63321 91 B1 | <input checked="" type="checkbox"/> | System for canceling speculatively fetched instructions following a branch mis-prediction in a microprocessor                                        | 712/240    |
| 34 | US 63306 62 B1 | <input checked="" type="checkbox"/> | Apparatus including a fetch unit to include branch history information to increase performance of multi-cylce pipelined branch prediction structures | 712/236    |
| 35 | US 63144 93 B1 | <input checked="" type="checkbox"/> | Branch history cache                                                                                                                                 | 711/137    |
| 36 | US 63016 47 B1 | <input checked="" type="checkbox"/> | Real mode translation look-aside buffer and method of operation                                                                                      | 711/207    |
| 37 | US 62826 29 B1 | <input checked="" type="checkbox"/> | Pipelined processor for performing parallel instruction recording and register assigning                                                             | 712/23     |
| 38 | US 62791 07 B1 | <input checked="" type="checkbox"/> | Branch selectors associated with byte ranges within an instruction cache for rapidly identifying branch predictions                                  | 712/239    |
| 39 | US 62726 24 B1 | <input checked="" type="checkbox"/> | Method and apparatus for predicting multiple conditional branches                                                                                    | 712/239    |
| 40 | US 62694 36 B1 | <input checked="" type="checkbox"/> | Superscalar microprocessor configured to predict return addresses from a return stack storage                                                        | 712/23     |
| 41 | US 62667 52 B1 | <input checked="" type="checkbox"/> | Reverse TLB for providing branch target address in a microprocessor having a physically-tagged cache                                                 | 711/200    |



US005881278A

**United States Patent [19]**

Tran et al.

[11] Patent Number: **5,881,278**[45] Date of Patent: **Mar. 9, 1999**

[54] **RETURN ADDRESS PREDICTION SYSTEM WHICH ADJUSTS THE CONTENTS OF RETURN STACK STORAGE TO ENABLE CONTINUED PREDICTION AFTER A MISPREDICTED BRANCH**

[75] Inventors: Thang M. Tran; Rupaka Mabalingaiah, both of Austin, Tex.

[73] Assignee: **Advanced Micro Devices, Inc., Sunnyvale, Calif.**

[21] Appl. No.: **550,296**

[22] Filed: **Oct. 30, 1995**

[51] Int. Cl.<sup>6</sup> ..... **C06F 9/32**

[52] U.S. Cl. ..... **395/589; 395/585**

[58] Field of Search ..... **395/589, 586, 395/585, 376**

**[56] References Cited**

**U.S. PATENT DOCUMENTS**

4,044,338 8/1977 Wolf.  
4,453,212 6/1984 Gaither et al.

(List continued on next page.)

**FOREIGN PATENT DOCUMENTS**

0259095 3/1988 European Pat. Off.  
0381471 8/1990 European Pat. Off.  
0459232 12/1991 European Pat. Off.  
0649084 4/1995 European Pat. Off.  
2263985 8/1993 United Kingdom.  
2263987 8/1993 United Kingdom.  
2281422 3/1995 United Kingdom.  
2287111 9/1995 United Kingdom.

**OTHER PUBLICATIONS**

Intel, "Chapter 2: Microprocessor Architecture Overview," pp. 2-1 through 2-4.

Michael Slater, "AMD's K5 Designed to Outrun Pentium," Microprocessor Report, vol. 8, No. 14, Oct. 24, 1994, 7 pages.

Sebastian Rupley and John Clyman, "P6: The Next Step?," PC Magazine, Sep. 12, 1995, 16 pages.

Tom R. Halfhill, "AMD K6 Takes on Intel P6," BYTE, Jan. 1996, 4 pages.

Dialog, Microprocessor Report, Oct. 24, 1994, pp. 1-7.  
Foreign Search Report dated Feb. 26, 1997 for PCT/US96/11842.

Tomasula, R. M., "An Efficient Algorithm for Exploiting Multiple Arithmetic Units," IBM Journal, Jan. 1967, pp. 25-33.

Dialog, Microprocessor Report, Oct. 24, 1994, pp. 1-7.  
IBM Technical Disclosure Bulletin, "Subroutine Call/Return Stack," Apr. 30, 1988, vol. 30, No. 11, pp. 221-225.

IBM Technical Disclosure Bulletin, "Highly Accurate Subroutine Stack Prediction Mechanism," Mar. 10, 1986, vol. 28, No. 10, pp. 4635-4637.

Yeh and Patt, "Branch History Table Indexing to Prevent Pipeline Bubbles in Wide-Issue Superscalar Processors," Dept. of Electrical Engineering, University of Michigan, Ann Arbor, 1993, pp. 164-175.

*Primary Examiner*—Thomas C. Lee

*Assistant Examiner*—Gautam R. Patel

*Attorney, Agent, or Firm*—Conley, Rose & Tayon; B. Noel Kivlin; Lawrence J. Merkel

**[57] ABSTRACT**

A return prediction unit is provided which is configured to predict return addresses for return instructions according to a return stack storage included therein. The return stack storage is a stack structure configured to store return addresses associated with previously detected call instructions. Return addresses may be predicted for return instructions early in the instruction processing pipeline of the microprocessor. In one embodiment, the return stack storage additionally stores a call tag and a return tag with each return address. The call tag and return tag respectively identify call and return instructions associated with the return address. These tags may be compared to a branch tag conveyed to the return prediction unit upon detection of a branch misprediction. The results of the comparisons may be used to adjust the contents of the return stack storage with respect to the misprediction. The return prediction unit may continue to predict return addresses correctly following a mispredicted branch instruction.

**39 Claims, 45 Drawing Sheets**



|    | Document ID    | U                                   | Title                                                                                                                                                                                                                         | Current OR |
|----|----------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 42 | US 62533 16 B1 | <input checked="" type="checkbox"/> | Three state branch history using one bit in a branch prediction mechanism                                                                                                                                                     | 712/239    |
| 43 | US 62471 23 B1 | <input checked="" type="checkbox"/> | Branch prediction mechanism employing branch selectors to select a branch prediction                                                                                                                                          | 712/239    |
| 44 | US 62471 22 B1 | <input checked="" type="checkbox"/> | Method and apparatus for performing branch prediction combining static and dynamic branch predictors                                                                                                                          | 712/239    |
| 45 | US 62232 80 B1 | <input checked="" type="checkbox"/> | Method and circuit for preloading prediction circuits in microprocessors                                                                                                                                                      | 712/240    |
| 46 | US 62021 42 B1 | <input checked="" type="checkbox"/> | Microcode scan unit for scanning microcode instructions using predecode data                                                                                                                                                  | 712/204    |
| 47 | US 61924 68 B1 | <input checked="" type="checkbox"/> | Apparatus and method for detecting microbranches early                                                                                                                                                                        | 712/231    |
| 48 | US 61890 91 B1 | <input checked="" type="checkbox"/> | Apparatus and method for speculatively updating global history and restoring same on branch misprediction detection                                                                                                           | 712/240    |
| 49 | US 61890 68 B1 | <input checked="" type="checkbox"/> | Superscalar microprocessor employing a data cache capable of performing store accesses in a single clock cycle                                                                                                                | 711/3      |
| 50 | US 61856 74 B1 | <input checked="" type="checkbox"/> | Method and apparatus for reconstructing the address of the next instruction to be completed in a pipelined processor                                                                                                          | 712/230    |
| 51 | US 61784 98 B1 | <input checked="" type="checkbox"/> | Storing predicted branch target address in different storage according to importance hint in branch prediction instruction                                                                                                    | 712/239    |
| 52 | US 61675 10 A  | <input checked="" type="checkbox"/> | Instruction cache configured to provide instructions to a microprocessor having a clock cycle time less than a cache access time of said instruction cache                                                                    | 712/239    |
| 53 | US 61516 72 A  | <input checked="" type="checkbox"/> | Methods and apparatus for reducing interference in a branch history table of a microprocessor                                                                                                                                 | 712/239    |
| 54 | US 61417 48 A  | <input checked="" type="checkbox"/> | Branch selectors associated with byte ranges within an instruction cache for rapidly identifying branch predictions                                                                                                           | 712/239    |
| 55 | US 61417 40 A  | <input checked="" type="checkbox"/> | Apparatus and method for microcode patching for generating a next address                                                                                                                                                     | 711/215    |
| 56 | US 61254 44 A  | <input checked="" type="checkbox"/> | Millimode capable computer system providing global branch history table disables and separate millicode disables which enable millicode disable to be turned off for some sections of code execution but not disabled for all | 712/245    |
| 57 | US 61192 22 A  | <input checked="" type="checkbox"/> | Combined branch prediction and cache prefetch in a microprocessor                                                                                                                                                             | 712/238    |
| 58 | US 61192 20 A  | <input checked="" type="checkbox"/> | Method of and apparatus for supplying multiple instruction strings whose addresses are discontinued by branch instructions                                                                                                    | 712/235    |
| 59 | US 61087 76 A  | <input checked="" type="checkbox"/> | Globally or selectively disabling branch history table operations during sensitive portion of millicode routine in millimode supporting computer                                                                              | 712/240    |
| 60 | US 61087 74 A  | <input checked="" type="checkbox"/> | Branch prediction with added selector bits to increase branch prediction capacity and flexibility with minimal added bits                                                                                                     | 712/240    |
| 61 | US 61065 73 A  | <input checked="" type="checkbox"/> | Apparatus and method for tracing microprocessor instructions                                                                                                                                                                  | 717/128    |
| 62 | US 61015 95 A  | <input checked="" type="checkbox"/> | Fetching instructions from an instruction cache using sequential way prediction                                                                                                                                               | 712/205    |
| 63 | US 61015 77 A  | <input checked="" type="checkbox"/> | Pipelined instruction cache and branch prediction mechanism therefor                                                                                                                                                          | 711/125    |

## U.S. PATENT DOCUMENTS

|           |         |                         |         |           |         |                         |         |
|-----------|---------|-------------------------|---------|-----------|---------|-------------------------|---------|
| 4,504,927 | 3/1985  | Callan .....            | 364/900 | 5,339,422 | 8/1994  | Brender et al. ....     | 395/700 |
| 4,807,115 | 2/1989  | Tong .....              |         | 5,355,459 | 10/1994 | Matsuo et al. ....      | 395/589 |
| 4,858,105 | 8/1989  | Kuriyama et al. .       |         | 5,454,087 | 9/1995  | Narita et al. ....      | 395/375 |
| 5,136,697 | 8/1992  | Johnson .....           |         | 5,526,498 | 6/1996  | Matsuo et al. ....      | 395/375 |
| 5,179,673 | 1/1993  | Steely, Jr. et al. .... | 395/586 | 5,564,118 | 10/1996 | Steely, Jr. et al. .... | 395/375 |
| 5,222,220 | 6/1993  | Mehta .....             | 395/375 | 5,574,871 | 11/1996 | Hoyt et al. ....        | 395/376 |
| 5,226,126 | 7/1993  | McFarland et al. .      |         | 5,584,001 | 12/1996 | Hoyt et al. ....        | 395/585 |
| 5,226,130 | 7/1993  | Favor et al. .          |         | 5,604,877 | 2/1997  | Hoyt et al. ....        | 395/590 |
| 5,274,817 | 12/1993 | Stahl .....             | 395/700 | 5,606,682 | 2/1997  | McGarity .....          | 395/414 |
| 5,313,634 | 5/1994  | Eickemeyer .....        | 395/700 | 5,623,614 | 4/1997  | Van Dyke et al. ....    | 395/587 |
|           |         |                         |         | 5,649,225 | 7/1997  | White et al. ....       | 395/800 |
|           |         |                         |         | 5,655,098 | 8/1997  | Witt et al. ....        | 395/386 |

|    | Document ID   | U                                   | Title                                                                                                                                                                               | Current OR |
|----|---------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 64 | US 60932 13 A | <input checked="" type="checkbox"/> | Flexible implementation of a system management mode (SMM) in a processor                                                                                                            | 703/27     |
| 65 | US 60818 87 A | <input checked="" type="checkbox"/> | System for passing an index value with each prediction in forward direction to enable truth predictor to associate truth value with particular branch instruction                   | 712/239    |
| 66 | US 60790 06 A | <input checked="" type="checkbox"/> | Stride-based data address prediction structure                                                                                                                                      | 711/213    |
| 67 | US 60790 05 A | <input checked="" type="checkbox"/> | Microprocessor including virtual address branch prediction and current page register to provide page portion of virtual and physical fetch address                                  | 711/213    |
| 68 | US 60790 03 A | <input checked="" type="checkbox"/> | Reverse TLB for providing branch target address in a microprocessor having a physically-tagged cache                                                                                | 711/200    |
| 69 | US 60732 30 A | <input checked="" type="checkbox"/> | Instruction fetch unit configured to provide sequential way prediction for sequential instruction fetches                                                                           | 712/205    |
| 70 | US 60651 15 A | <input checked="" type="checkbox"/> | Processor and method for speculatively executing instructions from multiple instruction streams indicated by a branch instruction                                                   | 712/235    |
| 71 | US 60650 91 A | <input checked="" type="checkbox"/> | Translation look-aside buffer slice circuit and method of operation                                                                                                                 | 711/3      |
| 72 | US 60556 30 A | <input checked="" type="checkbox"/> | System and method for processing a plurality of branch instructions by a plurality of storage devices and pipeline units                                                            | 712/240    |
| 73 | US 60527 73 A | <input checked="" type="checkbox"/> | DPGA-coupled microprocessors                                                                                                                                                        | 712/43     |
| 74 | US 60444 78 A | <input checked="" type="checkbox"/> | Cache with finely granular locked-down regions                                                                                                                                      | 714/42     |
| 75 | US 60322 52 A | <input checked="" type="checkbox"/> | Apparatus and method for efficient loop control in a superscalar microprocessor                                                                                                     | 712/233    |
| 76 | US 60322 41 A | <input checked="" type="checkbox"/> | Fast RAM for use in an address translation circuit and method of operation                                                                                                          | 711/207    |
| 77 | US 60165 45 A | <input checked="" type="checkbox"/> | Reduced size storage apparatus for storing cache-line-related data in a high frequency microprocessor                                                                               | 712/238    |
| 78 | US 60147 41 A | <input checked="" type="checkbox"/> | Apparatus and method for predicting an end of a microcode loop                                                                                                                      | 712/233    |
| 79 | US 60147 34 A | <input checked="" type="checkbox"/> | Superscalar microprocessor configured to predict return addresses from a return stack storage                                                                                       | 712/23     |
| 80 | US 60095 13 A | <input checked="" type="checkbox"/> | Apparatus and method for detecting microbranches early                                                                                                                              | 712/231    |
| 81 | US 60063 24 A | <input checked="" type="checkbox"/> | High performance superscalar alignment unit                                                                                                                                         | 712/204    |
| 82 | US 60031 28 A | <input checked="" type="checkbox"/> | Number of pipeline stages and loop length related counter differential based end-loop prediction                                                                                    | 712/241    |
| 83 | US 59960 71 A | <input checked="" type="checkbox"/> | Detecting self-modifying code in a pipelined processor with branch processing by comparing latched store address to subsequent target address                                       | 712/238    |
| 84 | US 59957 49 A | <input checked="" type="checkbox"/> | Branch prediction mechanism employing branch selectors to select a branch prediction                                                                                                | 712/239    |
| 85 | US 59875 61 A | <input checked="" type="checkbox"/> | Superscalar microprocessor employing a data cache capable of performing store accesses in a single clock cycle                                                                      | 711/3      |
| 86 | US 59833 37 A | <input checked="" type="checkbox"/> | Apparatus and method for patching an instruction by providing a substitute instruction or instructions from an external memory responsive to detecting an opcode of the instruction | 712/32     |



FIG. 1

|     | Document ID   | U                                   | Title                                                                                                                                                 | Current OR |
|-----|---------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 87  | US 59789 08 A | <input checked="" type="checkbox"/> | Computer instruction supply                                                                                                                           | 712/240    |
| 88  | US 59789 07 A | <input checked="" type="checkbox"/> | Delayed update register for an array                                                                                                                  | 712/239    |
| 89  | US 59789 06 A | <input checked="" type="checkbox"/> | Branch selectors associated with byte ranges within an instruction cache for rapidly identifying branch predictions                                   | 712/239    |
| 90  | US 59745 43 A | <input checked="" type="checkbox"/> | Apparatus and method for performing subroutine call and return operations                                                                             | 712/240    |
| 91  | US 59705 09 A | <input checked="" type="checkbox"/> | Hit determination circuit for selecting a data set based on miss determinations in other data sets and method of operation                            | 711/128    |
| 92  | US 59681 69 A | <input checked="" type="checkbox"/> | Superscalar microprocessor stack structure for judging validity of predicted subroutine return addresses                                              | 712/239    |
| 93  | US 59681 63 A | <input checked="" type="checkbox"/> | Microcode scan unit for scanning microcode instructions using predecode data                                                                          | 712/204    |
| 94  | US 59616 38 A | <input checked="" type="checkbox"/> | Branch prediction mechanism employing branch selectors to select a branch prediction                                                                  | 712/239    |
| 95  | US 59548 16 A | <input checked="" type="checkbox"/> | Branch selector prediction                                                                                                                            | 712/239    |
| 96  | US 59499 95 A | <input checked="" type="checkbox"/> | Programmable branch prediction system and method for inserting prediction operation which is independent of execution of program code                 | 712/239    |
| 97  | US 59467 18 A | <input checked="" type="checkbox"/> | Shadow translation look-aside buffer and method of operation                                                                                          | 711/207    |
| 98  | US 59467 05 A | <input checked="" type="checkbox"/> | Avoidance of cache synonyms                                                                                                                           | 711/108    |
| 99  | US 59408 58 A | <input checked="" type="checkbox"/> | Cache circuit with programmable sizing and method of operation                                                                                        | 711/139    |
| 100 | US 59387 61 A | <input checked="" type="checkbox"/> | Method and apparatus for branch target prediction                                                                                                     | 712/238    |
| 101 | US 59352 39 A | <input checked="" type="checkbox"/> | Parallel mask decoder and method for generating said mask                                                                                             | 712/224    |
| 102 | US 59336 29 A | <input checked="" type="checkbox"/> | Apparatus and method for detecting microbranches early                                                                                                | 712/248    |
| 103 | US 59336 26 A | <input checked="" type="checkbox"/> | Apparatus and method for tracing microprocessor instructions                                                                                          | 712/227    |
| 104 | US 59336 18 A | <input checked="" type="checkbox"/> | Speculative register storage for storing speculative results corresponding to register updated by a plurality of concurrently recorded instruction    | 712/217    |
| 105 | US 59283 58 A | <input checked="" type="checkbox"/> | Information processing apparatus which accurately predicts whether a branch is taken for a conditional branch instruction, using small-scale hardware | 712/239    |
| 106 | US 59266 42 A | <input checked="" type="checkbox"/> | RISC86 instruction set                                                                                                                                | 712/1      |
| 107 | US 59266 34 A | <input checked="" type="checkbox"/> | Limited run branch prediction                                                                                                                         | 712/239    |
| 108 | US 59207 13 A | <input checked="" type="checkbox"/> | Instruction decoder including two-way emulation code branching                                                                                        | 712/236    |
| 109 | US 59095 67 A | <input checked="" type="checkbox"/> | Apparatus and method for native mode processing in a RISC-based CISC processor                                                                        | 712/208    |



FIG. 2

|     | Document ID   | U                                   | Title                                                                                                                                                                   | Current OR |
|-----|---------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 110 | US 59078 60 A | <input checked="" type="checkbox"/> | System and method of retiring store data from a write buffer                                                                                                            | 711/117    |
| 111 | US 59013 07 A | <input checked="" type="checkbox"/> | Processor having a selectively configurable branch prediction unit that can access a branch prediction utilizing bits derived from a plurality of sources               | 712/240    |
| 112 | US 58988 65 A | <input checked="" type="checkbox"/> | Apparatus and method for predicting an end of loop for string instructions                                                                                              | 712/239    |
| 113 | US 58982 86 A | <input checked="" type="checkbox"/> | Digital servo control system for a data recording disk file with improved saturation modelling                                                                          | 318/569    |
| 114 | US 58929 36 A | <input checked="" type="checkbox"/> | Speculative register file for storing speculative register states and removing dependencies between instructions utilizing the register                                 | 712/216    |
| 115 | US 58871 52 A | <input checked="" type="checkbox"/> | Load/store unit with multiple oldest outstanding instruction pointers for completing store and load/store miss instructions                                             | 712/217    |
| 116 | US 58812 78 A | <input checked="" type="checkbox"/> | Return address prediction system which adjusts the contents of return stack storage to enable continued prediction after a mispredicted branch                          | 712/242    |
| 117 | US 58782 55 A | <input checked="" type="checkbox"/> | Update unit for providing a delayed update to a branch prediction array                                                                                                 | 712/240    |
| 118 | US 58753 25 A | <input checked="" type="checkbox"/> | Processor having reduced branch history table size through global branch history compression and method of branch prediction utilizing compressed global branch history | 712/240    |
| 119 | US 58753 24 A | <input checked="" type="checkbox"/> | Superscalar microprocessor which delays update of branch prediction information in response to branch misprediction until a subsequent idle clock                       | 712/238    |
| 120 | US 58753 15 A | <input checked="" type="checkbox"/> | Parallel and scalable instruction scanning unit                                                                                                                         | 712/204    |
| 121 | US 58731 15 A | <input checked="" type="checkbox"/> | Cache memory                                                                                                                                                            | 711/129    |
| 122 | US 58729 89 A | <input checked="" type="checkbox"/> | Processor having a register configuration suited for parallel execution control of loop processing                                                                      | 712/23     |
| 123 | US 58677 24 A | <input checked="" type="checkbox"/> | Integrated routing and shifting circuit and method of operation                                                                                                         | 712/22     |
| 124 | US 58676 98 A | <input checked="" type="checkbox"/> | Apparatus and method for accessing a branch target buffer                                                                                                               | 712/238    |
| 125 | US 58647 07 A | <input checked="" type="checkbox"/> | Superscalar microprocessor configured to predict return addresses from a return stack storage                                                                           | 712/23     |
| 126 | US 58646 97 A | <input checked="" type="checkbox"/> | Microprocessor using combined actual and speculative branch history prediction                                                                                          | 712/240    |
| 127 | US 58601 04 A | <input checked="" type="checkbox"/> | Data cache which speculatively updates a predicted data cache storage location with store data and subsequently corrects mispredicted updates                           | 711/137    |
| 128 | US 58600 17 A | <input checked="" type="checkbox"/> | Processor and method for speculatively executing instructions from multiple instruction streams indicated by a branch instruction                                       | 712/23     |
| 129 | US 58599 91 A | <input checked="" type="checkbox"/> | Parallel and scalable method for identifying valid instructions and a superscalar microprocessor including an instruction scanning unit employing the method            | 712/204    |
| 130 | US 58549 21 A | <input checked="" type="checkbox"/> | Stride-based data address prediction structure                                                                                                                          | 712/239    |
| 131 | US 58549 13 A | <input checked="" type="checkbox"/> | Microprocessor with an architecture mode control capable of supporting extensions of two distinct instruction-set architectures                                         | 712/210    |
| 132 | US 58527 27 A | <input checked="" type="checkbox"/> | Instruction scanning unit for locating instructions via parallel scanning of start and end byte information                                                             | 712/215    |

| Return PC | Call Tag | Ret. Tag | CV | RV | CRV | IxC | Start |
|-----------|----------|----------|----|----|-----|-----|-------|
|           |          |          |    |    |     |     |       |

**Return Stack Storage**  
252A

. . .

FIG. 2A

|     | Document ID      | U                                   | Title                                                                                                                                       | Current OR |
|-----|------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 133 | US 58505<br>32 A | <input checked="" type="checkbox"/> | Invalid instruction scan unit for detecting invalid predecode data corresponding to instructions being fetched                              | 712/213    |
| 134 | US 58484<br>33 A | <input checked="" type="checkbox"/> | Way prediction unit and a method for operating the same                                                                                     | 711/137    |
| 135 | US 58482<br>69 A | <input checked="" type="checkbox"/> | Branch predicting mechanism for enhancing accuracy in branch prediction by reference to data                                                | 712/239    |
| 136 | US 58389<br>40 A | <input checked="" type="checkbox"/> | Method and apparatus for rotating active instructions in a parallel data processor                                                          | 712/216    |
| 137 | US 58357<br>45 A | <input checked="" type="checkbox"/> | Hardware instruction scheduler for short execution unit latencies                                                                           | 712/215    |
| 138 | US 58322<br>97 A | <input checked="" type="checkbox"/> | Superscalar microprocessor load/store unit employing a unified buffer and separate pointers for load and store operations                   | 710/5      |
| 139 | US 58322<br>49 A | <input checked="" type="checkbox"/> | High performance superscalar alignment unit                                                                                                 | 712/204    |
| 140 | US 58288<br>74 A | <input checked="" type="checkbox"/> | Past-history filtered branch prediction                                                                                                     | 712/240    |
| 141 | US 58260<br>71 A | <input checked="" type="checkbox"/> | Parallel mask decoder and method for generating said mask                                                                                   | 712/224    |
| 142 | US 58225<br>75 A | <input checked="" type="checkbox"/> | Branch prediction storage for storing branch prediction information such that a corresponding tag may be routed with the branch instruction | 712/239    |
| 143 | US 58225<br>74 A | <input checked="" type="checkbox"/> | Functional unit with a pointer for mispredicted resolution, and a superscalar microprocessor employing the same                             | 712/233    |
| 144 | US 58225<br>59 A | <input checked="" type="checkbox"/> | Apparatus and method for aligning variable byte-length instructions to a plurality of issue positions                                       | 712/214    |
| 145 | US 58225<br>58 A | <input checked="" type="checkbox"/> | Method and apparatus for predecoding variable byte-length instructions within a superscalar microprocessor                                  | 712/213    |
| 146 | US 58190<br>59 A | <input checked="" type="checkbox"/> | Predecode unit adapted for variable byte-length instruction set processors and method of operating the same                                 | 712/213    |
| 147 | US 58190<br>57 A | <input checked="" type="checkbox"/> | Superscalar microprocessor including an instruction alignment unit with limited dispatch to decode units                                    | 712/204    |
| 148 | US 58157<br>00 A | <input checked="" type="checkbox"/> | Branch prediction table having pointers identifying other branches within common instruction cache lines                                    | 712/240    |
| 149 | US 58128<br>38 A | <input checked="" type="checkbox"/> | Branch history table                                                                                                                        | 712/239    |
| 150 | US 58092<br>71 A | <input checked="" type="checkbox"/> | Method and apparatus for changing flow of control in a processor                                                                            | 712/208    |
| 151 | US 57940<br>63 A | <input checked="" type="checkbox"/> | Instruction decoder including emulation using indirect specifiers                                                                           | 712/23     |
| 152 | US 57940<br>28 A | <input checked="" type="checkbox"/> | Shared branch prediction structure                                                                                                          | 712/240    |
| 153 | US 57939<br>40 A | <input checked="" type="checkbox"/> | Data processing apparatus                                                                                                                   | 714/1      |
| 154 | US 57817<br>89 A | <input checked="" type="checkbox"/> | Superscaler microprocessor employing a parallel mask decoder                                                                                | 712/23     |
| 155 | US 57747<br>10 A | <input checked="" type="checkbox"/> | Cache line branch prediction scheme that shares among sets of a set associative cache                                                       | 712/238    |



FIG. 3

|     | Document ID      | U                                   | Title                                                                                                                                                                                                    | Current OR |
|-----|------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 156 | US 57686<br>10 A | <input checked="" type="checkbox"/> | Lookahead register value generator and a superscalar microprocessor employing same                                                                                                                       | 712/23     |
| 157 | US 57649<br>46 A | <input checked="" type="checkbox"/> | Superscalar microprocessor employing a way prediction unit to predict the way of an instruction fetch address and to concurrently provide a branch prediction address corresponding to the fetch address | 712/239    |
| 158 | US 57581<br>43 A | <input checked="" type="checkbox"/> | Method for updating a branch history table in a processor which resolves multiple branches in a single cycle                                                                                             | 712/240    |
| 159 | US 57581<br>12 A | <input checked="" type="checkbox"/> | Pipeline processor with enhanced method and apparatus for restoring register-renaming information in the event of a branch misprediction                                                                 | 712/217    |
| 160 | US 57522<br>59 A | <input checked="" type="checkbox"/> | Instruction cache configured to provide instructions to a microprocessor having a clock cycle time less than a cache access time of said instruction cache                                               | 711/125    |
| 161 | US 57520<br>69 A | <input checked="" type="checkbox"/> | Superscalar microprocessor employing away prediction structure                                                                                                                                           | 712/23     |
| 162 | US 57489<br>76 A | <input checked="" type="checkbox"/> | Mechanism for maintaining data coherency in a branch history instruction cache                                                                                                                           | 712/240    |
| 163 | US 57404<br>18 A | <input checked="" type="checkbox"/> | Pipelined processor carrying out branch prediction by BTB                                                                                                                                                | 712/239    |
| 164 | US 57404<br>15 A | <input checked="" type="checkbox"/> | Instruction supplying apparatus with a branch target buffer having the contents so updated as to enhance branch prediction accuracy                                                                      | 712/238    |
| 165 | US 57375<br>90 A | <input checked="" type="checkbox"/> | Branch prediction system using limited branch target buffer updates                                                                                                                                      | 712/238    |
| 166 | US 57348<br>81 A | <input checked="" type="checkbox"/> | Detecting short branches in a prefetch buffer using target location information in a branch target cache                                                                                                 | 712/238    |
| 167 | US 57297<br>28 A | <input checked="" type="checkbox"/> | Method and apparatus for predicting, clearing and redirecting unpredicted changes in instruction flow in a microprocessor                                                                                | 712/234    |
| 168 | US 57218<br>55 A | <input checked="" type="checkbox"/> | Method for pipeline processing of instructions by controlling access to a reorder buffer using a register file outside the reorder buffer                                                                | 712/218    |
| 169 | US 57154<br>40 A | <input checked="" type="checkbox"/> | Branch instruction executing device for tracing branch instruments based on instruction type                                                                                                             | 712/233    |
| 170 | US 57040<br>54 A | <input checked="" type="checkbox"/> | Counterflow pipeline processor architecture for semi-custom application specific IC's                                                                                                                    | 712/212    |
| 171 | US 57014<br>48 A | <input checked="" type="checkbox"/> | Detecting segment limit violations for branch target when the branch unit does not supply the linear address                                                                                             | 712/233    |
| 172 | US 56969<br>19 A | <input checked="" type="checkbox"/> | Accessing a desk-type recording medium having reproduction control data                                                                                                                                  | 345/841    |
| 173 | US 56873<br>38 A | <input checked="" type="checkbox"/> | Method and apparatus for maintaining a macro instruction for refetching in a pipelined processor                                                                                                         | 712/205    |
| 174 | US 56871<br>10 A | <input checked="" type="checkbox"/> | Array having an update circuit for updating a storage location with a value stored in another storage location                                                                                           | 365/154    |
| 175 | US 56447<br>45 A | <input checked="" type="checkbox"/> | Apparatus for replacing data availability information for an instruction subsequent to a branch with previous availability information upon branch prediction failure                                    | 712/216    |
| 176 | US 56425<br>00 A | <input checked="" type="checkbox"/> | Method and apparatus for controlling instruction in pipeline processor                                                                                                                                   | 712/233    |
| 177 | US 56341<br>19 A | <input checked="" type="checkbox"/> | Computer processing unit employing a separate millicode branch history table                                                                                                                             | 712/240    |



FIG. 4A

|     | Document ID   | U                                   | Title                                                                                                                                                                       | Current OR |
|-----|---------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 178 | US 56320 28 A | <input checked="" type="checkbox"/> | Hardware support for fast software emulation of unimplemented instructions                                                                                                  | 703/26     |
| 179 | US 56196 62 A | <input checked="" type="checkbox"/> | Memory reference tagging                                                                                                                                                    | 712/216    |
| 180 | US 55840 09 A | <input checked="" type="checkbox"/> | System and method of retiring store data from a write buffer                                                                                                                | 711/117    |
| 181 | US 55840 01 A | <input checked="" type="checkbox"/> | Branch target buffer for dynamically predicting branch instruction outcomes using a predicted branch history                                                                | 712/238    |
| 182 | US 55817 19 A | <input checked="" type="checkbox"/> | Multiple block line prediction                                                                                                                                              | 712/207    |
| 183 | US 55772 17 A | <input checked="" type="checkbox"/> | Method and apparatus for a branch target buffer with shared branch pattern tables for associated branch predictions                                                         | 712/200    |
| 184 | US 55641 18 A | <input checked="" type="checkbox"/> | Past-history filtered branch prediction                                                                                                                                     | 712/240    |
| 185 | US 55532 55 A | <input checked="" type="checkbox"/> | Data processor with programmable levels of speculative instruction fetching and method of operation                                                                         | 712/235    |
| 186 | US 55220 53 A | <input checked="" type="checkbox"/> | Branch target and next instruction address calculation in a pipeline processor                                                                                              | 711/213    |
| 187 | US 55198 41 A | <input checked="" type="checkbox"/> | Multi instruction register mapper                                                                                                                                           | 711/202    |
| 188 | US 55176 14 A | <input checked="" type="checkbox"/> | Data compression/encryption processing apparatus                                                                                                                            | 714/1      |
| 189 | US 55111 75 A | <input checked="" type="checkbox"/> | Method and apparatus for store-into-instruction-stream detection and maintaining branch prediction cache consistency                                                        | 712/216    |
| 190 | US 55048 70 A | <input checked="" type="checkbox"/> | Branch prediction device enabling simultaneous access to a content-addressed memory for retrieval and registration                                                          | 712/238    |
| 191 | US 54715 97 A | <input checked="" type="checkbox"/> | System and method for executing branch instructions wherein branch target addresses are dynamically selectable under programmer control from writable branch address tables | 711/215    |
| 192 | US 54540 89 A | <input checked="" type="checkbox"/> | Branch look ahead adder for use in an instruction pipeline sequencer with multiple instruction decoding                                                                     | 711/213    |
| 193 | US 54248 82 A | <input checked="" type="checkbox"/> | Signal processor for discriminating recording data                                                                                                                          | 360/46     |
| 194 | US 53945 30 A | <input checked="" type="checkbox"/> | Arrangement for predicting a branch target address in the second iteration of a short loop                                                                                  | 712/240    |
| 195 | US 53677 03 A | <input checked="" type="checkbox"/> | Method and system for enhanced branch history prediction accuracy in a superscalar processor system                                                                         | 712/23     |
| 196 | US 53275 36 A | <input checked="" type="checkbox"/> | Microprocessor having branch prediction function                                                                                                                            | 712/238    |
| 197 | US 53136 34 A | <input checked="" type="checkbox"/> | Computer system branch prediction of subroutine returns                                                                                                                     | 712/240    |
| 198 | US 52281 31 A | <input checked="" type="checkbox"/> | Data processor with selectively enabled and disabled branch prediction operation                                                                                            | 712/240    |
| 199 | US 52261 30 A | <input checked="" type="checkbox"/> | Method and apparatus for store-into-instruction-stream detection and maintaining branch prediction cache consistency                                                        | 712/238    |
| 200 | US 51931 56 A | <input checked="" type="checkbox"/> | Data processor with pipeline which disables exception processing for non-taken branches                                                                                     | 712/239    |

|   |   |   |   |   |   |
|---|---|---|---|---|---|
|   |   |   |   |   |   |
|   |   |   |   |   |   |
|   |   |   |   |   |   |
|   |   |   |   |   |   |
| C | O | - | 1 | 0 | 0 |
| B | O | - | 1 | 0 | 1 |
| A | O | - | 1 | 0 | 1 |

Return Stack Storage 252

Pointer → 444

442

440

FIG. 4B

|   |   |   |   |   |   |
|---|---|---|---|---|---|
|   |   |   |   |   |   |
|   |   |   |   |   |   |
|   |   |   |   |   |   |
|   |   |   |   |   |   |
| D | 3 | - | 1 | 0 | 0 |
| C | O | 2 | 1 | 1 | 0 |
| B | O | - | 1 | 0 | 1 |
| A | O | - | 1 | 0 | 1 |

Return Stack Storage 252

446

Pointer → 444

442

440

FIG. 4C

|   | L # | Hits | Search Text                                                                          | DBs                                 |
|---|-----|------|--------------------------------------------------------------------------------------|-------------------------------------|
| 1 | L2  | 869  | (access\$3 writ\$3 updat\$3) near10 ((branch near5 (table history predict\$3)) bht)  | USPAT;<br>US-PGPUB                  |
| 2 | L4  | 207  | (access\$3 writ\$3 updat\$3) near10 ((branch near5 (table history predict\$3)) bht)  | EPO;<br>JPO;<br>DERWENT;<br>IBM TDB |
| 3 | L7  | 220  | 2 near10 (control controlled controlling simultaneous\$3 clock cycle)                | USPAT;<br>US-PGPUB                  |
| 4 | L6  | 29   | 4 near10 (control controlled controlling simultaneous\$3 clock cycle)                | EPO;<br>JPO;<br>DERWENT;<br>IBM TDB |
| 5 | L8  | 1245 | (access\$3 writ\$3 updat\$3) near20 ((branch near20 (table history predict\$3)) bht) | USPAT;<br>US-PGPUB                  |
| 6 | L10 | 258  | (access\$3 writ\$3 updat\$3) near20 ((branch near20 (table history predict\$3)) bht) | EPO;<br>JPO;<br>DERWENT;<br>IBM TDB |
| 7 | L12 | 11   | 10 near30 (control controlled controlling simultaneous\$3 clock cycle) not 6         | EPO;<br>JPO;<br>DERWENT;<br>IBM TDB |
| 8 | L9  | 73   | 8 near30 (control controlled controlling simultaneous\$3 clock cycle) not 7          | USPAT;<br>US-PGPUB                  |



FIG. 14

|    | Document ID                 | U                                   | Title                                                                                                                                                                            | Current OR |
|----|-----------------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 1  | JP<br>08286<br>913 A        | <input type="checkbox"/>            | METHOD AND DEVICE FOR GENERATING ADDRESS OF INSTRUCTION TO BE FINISHED NEXT IN PIPELINE PROCESSOR                                                                                |            |
| 2  | JP<br>04148<br>359 A        | <input checked="" type="checkbox"/> | HIGH SPEED FRONT END PROCESSOR                                                                                                                                                   |            |
| 3  | JP<br>01284<br>927 A        | <input checked="" type="checkbox"/> | INFORMATION PROCESSOR                                                                                                                                                            |            |
| 4  | JP<br>63208<br>941 A        | <input checked="" type="checkbox"/> | MANAGING SYSTEM FOR UPDATING HISTORY OF PROGRAM PATH                                                                                                                             |            |
| 5  | JP<br>61257<br>041 A        | <input checked="" type="checkbox"/> | PACKET EXCHANGE SYSTEM OF HIERARCHY EXCHANGE SYSTEM                                                                                                                              |            |
| 6  | JP<br>55041<br>515 A        | <input checked="" type="checkbox"/> | HOME COMPUTER                                                                                                                                                                    |            |
| 7  | EP<br>73683<br>0 A1         | <input checked="" type="checkbox"/> | Method and apparatus for reconstructing the address of the next instruction to be completed in a pipelined processor                                                             |            |
| 8  | NN920<br>1330               | <input checked="" type="checkbox"/> | Using History to Improve the Handling of Address Generation Interlocks in Branch Instructions.                                                                                   |            |
| 9  | US<br>20020<br>07833<br>2 A | <input checked="" type="checkbox"/> | Computer system includes bank control logic to ensure that no two look-ups access same bank in same clock cycle                                                                  |            |
| 10 | GB<br>23213<br>23 A         | <input type="checkbox"/>            | Branch prediction method for computer program - involves accessing branch target buffer using pointer of instruction whose interval from fetch of branch instruction is smallest |            |
| 11 | EP<br>21074<br>2 A          | <input checked="" type="checkbox"/> | Processing information through multi-program system - using with computer program sequence, command shell with set of programs and program control files                         |            |



FIG. 5

|    | Document ID         | U                                   | Title                                                                                                                                                                  | Current OR   |
|----|---------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 1  | US 20020 13992 7 A1 | <input type="checkbox"/>            | Method of and system for detecting and correcting mode switching in diffractive-based laser scanning systems                                                           | 250/235      |
| 2  | US 20020 11213 1 A1 | <input checked="" type="checkbox"/> | Specifying access control and caching on operands                                                                                                                      | 711/141      |
| 3  | US 20020 06935 1 A1 | <input checked="" type="checkbox"/> | Memory data access structure and method suitable for use in a processor                                                                                                | 712/239      |
| 4  | US 20020 06908 6 A1 | <input checked="" type="checkbox"/> | Web linked database for tracking clinical activities and competencies and evaluation of program resources and program outcomes                                         | 705/2        |
| 5  | US 20020 04139 6 A1 | <input checked="" type="checkbox"/> | Storage medium control apparatus, image forming apparatus using the same, and control method therefor                                                                  | 358/1.1<br>7 |
| 6  | US 20020 03567 7 A1 | <input checked="" type="checkbox"/> | METHOD AND APPARATUS FOR PRE-PROCESSING INSTRUCTIONS FOR A PROCESSOR                                                                                                   | 712/217      |
| 7  | US 20010 03749 7 A1 | <input checked="" type="checkbox"/> | Apparatus and method for generating optimization objects                                                                                                               | 717/160      |
| 8  | US 64424 79 B1      | <input checked="" type="checkbox"/> | Method and apparatus for a location sensitive database                                                                                                                 | 701/213      |
| 9  | US 64381 81 B1      | <input checked="" type="checkbox"/> | Efficient metric memory configuration for a Viterbi decoder                                                                                                            | 375/341      |
| 10 | US 64250 76 B1      | <input checked="" type="checkbox"/> | Instruction prediction based on filtering                                                                                                                              | 712/239      |
| 11 | US 63603 18 B1      | <input checked="" type="checkbox"/> | Configurable branch prediction for a processor performing speculative execution                                                                                        | 712/240      |
| 12 | US 63518 39 B1      | <input checked="" type="checkbox"/> | State metric memory of viterbi decoder and its decoding method                                                                                                         | 714/795      |
| 13 | US 63393 83 B1      | <input checked="" type="checkbox"/> | Traffic signal control apparatus optimizing signal control parameter by rolling horizon scheme                                                                         | 340/907      |
| 14 | US 62928 79 B1      | <input checked="" type="checkbox"/> | Method and apparatus to specify access control list and cache enabling and cache coherency requirement enabling on individual operands of an instruction of a computer | 711/214      |
| 15 | US 62826 39 B1      | <input checked="" type="checkbox"/> | Configurable branch prediction for a processor performing speculative execution                                                                                        | 712/240      |
| 16 | US 62821 83 B1      | <input checked="" type="checkbox"/> | Method for authorizing couplings between devices in a capability addressable network                                                                                   | 370/338      |
| 17 | US 62302 60 B1      | <input checked="" type="checkbox"/> | Circuit arrangement and method of speculative instruction execution utilizing instruction history caching                                                              | 712/239      |
| 18 | US 61700 54 B1      | <input checked="" type="checkbox"/> | Method and apparatus for predicting target addresses for return from subroutine instructions utilizing a return address cache                                          | 712/242      |
| 19 | US 61548 33 A       | <input checked="" type="checkbox"/> | System for recovering from a concurrent branch target buffer read with a write allocation by invalidating and then reinstating the instruction pointer                 | 712/238      |
| 20 | US 61449 82 A       | <input checked="" type="checkbox"/> | Pipeline processor and computing system including an apparatus for tracking pipeline resources                                                                         | 709/104      |



FIG. 6

**Figure 1.1.1**

**x86 Register Organization**

| 31 | 16 | 15 | 8  | 7  | 0 | 16-bit | 32-bit |
|----|----|----|----|----|---|--------|--------|
|    |    |    | AH | AL |   | AX     | EAX    |
|    |    |    | DH | DL |   | DX     | DAX    |
|    |    |    | CH | CL |   | CX     | CAX    |
|    |    |    | BH | BL |   | BX     | BAX    |
|    |    |    |    |    |   |        |        |
|    |    |    | BP |    |   |        | EBP    |
|    |    |    | SI |    |   |        | ESI    |
|    |    |    | DI |    |   |        | EDI    |
|    |    |    | SP |    |   |        | ESP    |

FIG. 7

|    | Document ID   | U                                   | Title                                                                                                                                                                             | Current OR |
|----|---------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 21 | US 61087 77 A | <input checked="" type="checkbox"/> | Configurable branch prediction for a processor performing speculative execution                                                                                                   | 712/240    |
| 22 | US 61087 75 A | <input checked="" type="checkbox"/> | Dynamically loadable pattern history tables in a multi-task microprocessor                                                                                                        | 712/240    |
| 23 | US 61087 69 A | <input checked="" type="checkbox"/> | Dependency table for reducing dependency checking hardware                                                                                                                        | 712/216    |
| 24 | US 61015 86 A | <input checked="" type="checkbox"/> | Memory access control circuit                                                                                                                                                     | 711/163    |
| 25 | US 60921 87 A | <input checked="" type="checkbox"/> | Instruction prediction based on filtering                                                                                                                                         | 712/239    |
| 26 | US 60852 38 A | <input checked="" type="checkbox"/> | Virtual LAN system                                                                                                                                                                | 709/223    |
| 27 | US 60524 41 A | <input checked="" type="checkbox"/> | Voice response service apparatus                                                                                                                                                  | 379/88.16  |
| 28 | US 60444 59 A | <input checked="" type="checkbox"/> | Branch prediction apparatus having branch target buffer for effectively processing branch instruction                                                                             | 712/237    |
| 29 | US 59408 57 A | <input checked="" type="checkbox"/> | Instruction cache memory apparatus with advanced read function that predicts whether to read out a next instruction block including an address register, a counter and a selector | 711/137    |
| 30 | US 59403 78 A | <input checked="" type="checkbox"/> | Call control in exchange suitable for intelligent network                                                                                                                         | 370/259    |
| 31 | US 58600 18 A | <input checked="" type="checkbox"/> | Method for tracking pipeline resources in a superscalar processor                                                                                                                 | 712/23     |
| 32 | US 58570 89 A | <input checked="" type="checkbox"/> | Floating point stack and exchange instruction                                                                                                                                     | 712/222    |
| 33 | US 58451 02 A | <input checked="" type="checkbox"/> | Determining microcode entry points and prefix bytes using a parallel logic technique                                                                                              | 712/211    |
| 34 | US 58394 83 A | <input checked="" type="checkbox"/> | Beverage dispenser with serving time monitor                                                                                                                                      | 141/1      |
| 35 | US 58357 54 A | <input checked="" type="checkbox"/> | Branch prediction system for superscalar processor                                                                                                                                | 712/239    |
| 36 | US 58156 99 A | <input checked="" type="checkbox"/> | Configurable branch prediction for a processor performing speculative execution                                                                                                   | 712/239    |
| 37 | US 58092 94 A | <input checked="" type="checkbox"/> | Parallel processing unit which processes branch instructions without decreased performance when a branch is taken                                                                 | 712/233    |
| 38 | US 58058 78 A | <input checked="" type="checkbox"/> | Method and apparatus for generating branch predictions for multiple branch instructions indexed by a single instruction pointer                                                   | 712/239    |
| 39 | US 57969 88 A | <input checked="" type="checkbox"/> | Method and system using dedicated location to share information between real mode and protected mode drivers                                                                      | 709/321    |
| 40 | US 57963 56 A | <input checked="" type="checkbox"/> | Data compressing apparatus, data restoring apparatus and data compressing/restoring system                                                                                        | 341/51     |
| 41 | US RE357 94 E | <input checked="" type="checkbox"/> | System for reducing delay for execution subsequent to correctly predicted branch instruction using fetch information stored with each block of instructions in cache              | 712/239    |
| 42 | US 56969 55 A | <input checked="" type="checkbox"/> | Floating point stack and exchange instruction                                                                                                                                     | 712/222    |
| 43 | US 56842 60 A | <input checked="" type="checkbox"/> | Apparatus and method for generation and synthesis of audio                                                                                                                        | 84/604     |



FIG. 8



FIG. 9

|    | Document ID      | U                                   | Title                                                                                                                                                | Current OR    |
|----|------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 44 | US 56756<br>45 A | <input checked="" type="checkbox"/> | Method and apparatus for securing executable programs against copying                                                                                | 713/187       |
| 45 | US 56550<br>96 A | <input checked="" type="checkbox"/> | Method and apparatus for dynamic scheduling of instructions to ensure sequentially coherent data in a processor employing out-of-order execution     | 712/200       |
| 46 | US 56491<br>08 A | <input checked="" type="checkbox"/> | Combined progressive and source routing control for connection-oriented communications networks                                                      | 709/241       |
| 47 | US 56340<br>27 A | <input checked="" type="checkbox"/> | Cache memory system for multiple processors with collectively arranged cache tag memories                                                            | 711/3         |
| 48 | US 56048<br>87 A | <input checked="" type="checkbox"/> | Method and system using dedicated location to share information between real and protected mode device drivers                                       | 703/27        |
| 49 | US 55926<br>34 A | <input checked="" type="checkbox"/> | Zero-cycle multi-state branch cache prediction data processing system and method thereof                                                             | 712/239       |
| 50 | US 55686<br>31 A | <input checked="" type="checkbox"/> | Multiprocessor system with a shared control store accessed with predicted addresses                                                                  | 712/248       |
| 51 | US 54813<br>64 A | <input checked="" type="checkbox"/> | Apparatus for adaptively generating a decoder table for variable-length codes using a stored coding table                                            | 382/244       |
| 52 | US 54637<br>46 A | <input checked="" type="checkbox"/> | Data processing system having prediction by using an embedded guess bit of remapped and compressed opcodes                                           | 712/240       |
| 53 | US 54598<br>45 A | <input checked="" type="checkbox"/> | Instruction pipeline sequencer in which state information of an instruction travels through pipe stages until the instruction execution is completed | 712/248       |
| 54 | US 54541<br>17 A | <input checked="" type="checkbox"/> | Configurable branch prediction for a processor performing speculative execution                                                                      | 712/23        |
| 55 | US 54539<br>27 A | <input checked="" type="checkbox"/> | Data processor for processing branch instructions                                                                                                    | 712/235       |
| 56 | US 53882<br>39 A | <input checked="" type="checkbox"/> | Operand address modification system                                                                                                                  | 711/220       |
| 57 | US 53534<br>21 A | <input checked="" type="checkbox"/> | Multi-prediction branch prediction mechanism                                                                                                         | 712/240       |
| 58 | US 53455<br>71 A | <input checked="" type="checkbox"/> | System for controlling branch history table                                                                                                          | 712/240       |
| 59 | US 53177<br>00 A | <input checked="" type="checkbox"/> | Program history for pipelined processor including temporary storage queues for storing branch addresses                                              | 712/240       |
| 60 | US 53053<br>75 A | <input checked="" type="checkbox"/> | Information service apparatus                                                                                                                        | 379/88.<br>27 |
| 61 | US 53052<br>17 A | <input checked="" type="checkbox"/> | Method and system for controlling automatic guided vehicle                                                                                           | 701/25        |
| 62 | US 53032<br>34 A | <input checked="" type="checkbox"/> | Random access data communication system with slot assignment capability for contending users                                                         | 370/442       |
| 63 | US 52952<br>64 A | <input checked="" type="checkbox"/> | Modularly structured integrated services digital network (ISDN) communication system                                                                 | 709/103       |
| 64 | US 52671<br>90 A | <input checked="" type="checkbox"/> | Simultaneous search-write content addressable memory                                                                                                 | 365/49        |
| 65 | US 52220<br>64 A | <input checked="" type="checkbox"/> | Bridge apparatus                                                                                                                                     | 370/401       |
| 66 | US 52030<br>06 A | <input checked="" type="checkbox"/> | System for selecting next instruction address between unit incremented address and address from table specified by operating condition signals       | 711/213       |



FIG. 10



FIG. 11

|    | Docum<br>ent<br>ID  | U                                   | Title                                                                                                                                         | Current<br>OR |
|----|---------------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| 67 | US<br>51366<br>96 A | <input checked="" type="checkbox"/> | High-performance pipelined central processor for predicting the occurrence of executing single-cycle instructions and multicycle instructions | 712/240       |
| 68 | US<br>50723<br>64 A | <input checked="" type="checkbox"/> | Method and apparatus for recovering from an incorrect branch prediction in a processor that executes a family of instructions in parallel     | 712/215       |
| 69 | US<br>47605<br>19 A | <input checked="" type="checkbox"/> | Data processing apparatus and method employing collision detection and prediction                                                             | 712/217       |
| 70 | US<br>47501<br>12 A | <input checked="" type="checkbox"/> | Data processing apparatus and method employing instruction pipelining                                                                         | 712/217       |
| 71 | US<br>45478<br>46 A | <input checked="" type="checkbox"/> | Accessory interface circuit for universal multi-station document inserter                                                                     | 700/9         |
| 72 | US<br>44505<br>25 A | <input checked="" type="checkbox"/> | Control unit for a functional processor                                                                                                       | 712/243       |
| 73 | US<br>43631<br>03 A | <input checked="" type="checkbox"/> | Device for following and estimating the local state of picture contours                                                                       | 382/242       |



FIG. 12



FIG. 13